import router from '@/router' // 引入路由实例
import store from '@/store' // 引入vuex store实例
import NProgress from 'nprogress' // 引入一份进度条插件
import 'nprogress/nprogress.css' // 引入进度条样式
const whiteList = ['/login', '/404']//白名单
router.beforeEach(async (to,from,next) => {
    
    NProgress.start() // 开启进度条
    if (store.getters.token) {
      //登陆了
      if(to.path === '/login') {
        //登陆了还要去登录页
        next('/')
      }else {
        if(!store.getters.userId) {
          await store.dispatch('user/getInfoApiActions')
        }
        next()
      }
    }else {
      //未登录
      if(whiteList.includes(to.path)) {
        //在白名单中
        next()
      }else {
        //非法访问
        next('/login')
      }
    }
    NProgress.done() // 手动强制关闭一次  为了解决 手动切换地址时  进度条的不关闭的问题
  })
  // 后置守卫
router.afterEach(function() {
    NProgress.done() // 关闭进度条
  })